查看原文
其他

吊炸天的 JD-hotkey !京东开源!单机 QPS 高达 370000

点击关注👉 民工哥技术之路 2022-12-31

点击关注公众号,回复“1024”获取2TB学习资源!

HotKey在618稳定版0.2版基础上,引入了protobuf序列化方式,并优化了传输对象。

worker单机性能从618大促稳定版的20万QPS稳定,30万极限,提升至30万稳定,37万极限。且cpu峰值下降了15%。

该中间件目前在京东内部10余个核心部门接入使用,服务于京东App服务端前台、中台,数据中台等多个核心业务线。

系统架构

京东APP后台热数据探测框架,历经多次高压压测和2020年京东618大促考验。在上线运行的这段时间内,每天探测的key数量数十亿计,精准捕获了大量爬虫、刷子用户,另准确探测大量热门商品并毫秒级推送到各个服务端内存,大幅降低了热数据对数据层的查询压力,提升了应用性能。

该框架历经多次压测,性能指标主要有两个

1、探测性能:

8核单机worker端每秒可接收处理16万个key探测任务,16核单机至少每秒平稳处理30万以上,实际压测达到37万,CPU平稳支撑,框架无异常。

2、推送性能:

在高并发写入的同时,对外推送目前性能约平稳推送每秒10-12万次,譬如有1千台server,一台worker上每秒产生了100个热key,那么这1秒会平稳推送100 * 1000 = 10万次,10万次推送会明确在1s内全部送达。如果是写入少,推送多,以纯推送来计数的话,该框架每秒可稳定对外推送40-60万次平稳,80万次极限可撑几秒。

3、在真实业务场景中:

可用1:1000的比例,即1台worker支撑1000台业务服务端的key探测任务,即可带来极大的数据存储资源节省(如对redis集群的扩充)。

介绍

对任意突发性的无法预先感知的热点请求,包括并不限于热点数据(如突发大量请求同一个商品)、热用户(如爬虫、刷子)、热接口(突发海量请求同一个接口)等,进行毫秒级精准探测到。然后对这些热数据、热用户等,推送到该应用部署的所有机器JVM内存中,(关注微信公众号民工哥技术之路,后台回复关键字 Java全栈知识体系 可以获取一份学习路线PDF)以大幅减轻对后端数据存储层的冲击,并可以由客户端决定如何使用这些热key(譬如对热商品做本地缓存、对热用户进行拒绝访问、对热接口进行熔断或返回默认值)。这些热key在整个应用集群内保持一致性。

核心功能:热数据探测并推送至集群各个服务器。

适用场景

  • 1、 mysql热数据本地缓存
  • 2、 redis热数据本地缓存
  • 3、 黑名单用户本地缓存
  • 4、 爬虫用户限流
  • 5、 接口、用户维度限流
  • 6、 单机接口、用户维度限流限流
  • 7、 集群用户维度限流
  • 8、 集群接口维度限流

该开源项目战略意义重大,经历百万级并发,参与京东开源中间件项目建设,一直在等你。

界面效果

开源地址

https://gitee.com/jd-platform-opensource/hotkey


推荐阅读 点击标题可跳转
装逼神器,用起来真香!网友们直呼 666
牛逼,竟然有人开源躺平学习资料!
2021 最牛逼的监控系统,它始终位列第一!
ES 不香吗,为啥还要 ClickHouse?
一款超牛逼的神仙级接私活软件!吊到不行
一、二线城市 IT 公司大盘点!建议收藏
SpringCloud+Jenkins+GitLab实现自动化构建与部署
MySQL 大批量插入,如何过滤掉重复数据?
PS:因为公众号平台更改了推送规则,如果不想错过内容,记得读完点一下在看,加个星标,这样每次新文章推送才会第一时间出现在你的订阅列表里。
随手在看、转发是最大的支持!

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存